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(57) Abstract: A record carrier (1) according to the inven- 
tion comprises information organized in a plurality of files 
containing audio visual data (1 1) and playback control data 
(12) for controlling playback of the audio visual data on a 
playback device while enabling user interaction. The infor- 
mation further comprises priority inf ormanon (priority), in- 
(heating the relative priority with which the files are to be 
stored in a cache me mo ry (39) of the playback device. The 
invention also relates to a device for playing back a record 
carrier and a method for playing back a record carrier. 
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Record carrier, device for playing back a record carrier, method for playing back a record 
carrier, device for recording a record carrier and method for recording a record carrier. 



The invention pertains to a record carrier. 

The invention also pertains to a device for playing back a record carrier. 
The invention further pertajns to a method for playing back a record carrier. 

5 

Several standards are in development for digital storage and reproduction of 
audiovisual data such as the SVCD and DVD standard. SVCD describes storage of 
audiovisual data in the form of MPEG2-files, which may be reproduced under control of a so 
called Play Sequence Descriptor (PSD). The audiovisual data and the PSD are stored at the 

10 record carrier. The.PSD is a set of control structures that enables the playback of 

preprogrammed sequences with user selection and interaction. User selection may for 
example take place by menus which are displayed on a display device, and from which the 
user may select an item by poinung at a position of the display device with a pointing device 
such as a mouse. Reading such a menu from the record carrier may delay the interaction 

15 speed. 



It is an object of the invention to provide a record carrier, a device for 
reproducing audiovisual data from a record carrier and a method for reproducing audiovisual 
20 data from the record carrier which allow a higher interaction speed. 

To that end a record carrier of the invention comprises information organized 
in a plurality of files containing audio visual data and playback control data for controlling 
playback of the audiovisual data on a playback device while enabling user interaction, the 
information further comprising priority information, indicating the relative priority with 
25 which the files are to be stored in a cache memory of the playback device. 

A record carrier according to the invention is particularly suitable for playback 
on a playback device according to the invention. A playback device according to the 
invention comprises read means for reading the data from a record carrier, a cache memory 
for storing data from the record carrier, user input means for receiving user input, control 



WOM/35416 2 PCT/EPOO/1,,,4 

means for processing the control data, and reproduction means for reproducing the audio 
visual data, the device being adapted to read priority information and to store files into the 
cache memory with a priority determined by this priority information. 

Preferably the priority information (priority) is related to an estimated 
frequency with which the said data is accessed. The priority information enables the playback 
device to store frequently accessed control data in its cache memory, while keeping less 
frequently accessed files at the record carrier. Such control data comprises for example menu 
items. This type of data is often used to request information from a user how to proceed with 
the playback. Loading such a menu item from the record carrier may take one or two seconds 
and therewith hampers the speed of interaction between the playback device and the user. By 
providing the priority information at the record carrier a playback device according to the 
invention is enabled to store this type of data in a cache memory and to therewith improve 
the interaction speed. The cache memory may be relatively small as the priority information 
indicates which information is the most relevant to store therein. The priority information 
preferably discerns at least 8 levels. This enables a playback device having only a relatively 
small cache memory to select only the most frequently accessed files for storage in the cache 
memory. If on the other hand such a record carrier is played back at a playback device having 
a greater cache memory, in addition to those files other files may be stored in the cache 
memory which are less frequently accessed, but still important. 

It is possible to attach each item of priority information to the file to which it 
corresponds. Preferably however, the priority information is contained in a single file. This 
allows a playback device to retrieve the priority information with one fi le access. 

An attractive embodiment of the playback device according to the invention is 
characterized by means for rewriting the priority information at the record carrier in 
accordance with the frequency with which the files are actually accessed by a user. This 
allows the playback device to adapt the record carrier to the profile of a particular user. 

The invention also provides a method for playback of a record carrier 
comprising information organized in a plurality of files containing audiovisual data and 
playback control data for controlling playback of the audiovisual data while enabling user 
interaction, which method comprises the steps of 

determining whether a cache memory does have sufficient unoccupied space, 
if it is determined that the cache memory does not have sufficient unoccupied 
space, then determining whether the cache memory does have space sufficiently large which 



a. 
aa. 
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is occupied by one or more further data files having a priority value lower than the priority 
value of the first data file, 

aaa. if the outcome of step aa is true, then overwriting said one or more further data 

files by the first data file. 

5 A preferred embodiment of said method is characterised in that if the outcome 

of step a is true then 

ab it is determined whether the first data file has a priority value higher than a 

predetermined value, 

aba if the outcome of step ab is true then the first data unit is loaded from the 

10 record carrier into the cache memory. 

The advantage of this embodiment is that it is prevented that files having a too 
low priority would be loaded into the cache memory. Such files generally would only stay 
relatively short into the cache memory as they would be overwritten by files having a higher 
priority. 

15 The cache memory of a playback device according to the invention may also 

be loaded during an initialisation stage of the device by means of the following method for 
playback of a record carrier comprising inforimation organized in a plurali ty of files 
containing audiovisual data and playback control data for controlling playback of the 
audiovisual data while enabling user interaction, which method comprises a procedure for 

20 loading files in a cache memory comprising the steps of 
d setting a reference priority value, 

e for a plurality of files examining whether a priority value assigned thereto is 

higher than the reference priority value, 

ea if lhe outcome of step e is true examining whether the cache memory 

25 comprises sufficient space for storing the said data unit, 

eaa if the outcome of step ea is true then loading said data unit into said 

space, 

f reducing the reference priority value, 

g determining whether the reference priority value is greater than or equal to a 

30 bottom priority value, 

8 a repeating steps d to g if the outcome of step g is true. 

A record canier according to the invention may be recorded with a device for 
recording a record carrier comprising information organized in a plurality of files containing 
audio visual data and playback control data for controlling playback of the audiovisual data 
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on a playback device while enabling user interaction, the information further comprising 
priority information, indicating the relative pricmty with which the files are to be stored in a 
cache memory of the playback device, 
the playback device comprising 
5 - means for obtaining the audiovisual data, 

means for composing the control data, 

priority determining means for determining the priority information, 
- formatting means for formatting the audiovisual data and the control data into 

files, 

10 recording means for recording the information comprising the priority 

information, the audiovisual data and the control data at the record carrier. 

A record carrier according to the invention may be recorded with a method for 
recording a record carrier comprising information organized in a plurality of files containing 
audio visual data and playback control data for controlling playback of the audiovisual data 
15 on a playback device while enabling user interaction,, the information further comprising 
priority information, indicating the relative priority with which the files are to be stored in a 
cache memory of the playback device, 
the method comprising the steps of 

obtaining the audiovisual data, 
20 - composing the control data, 

determining the priority information, 

formatting the audiovisual data and the control data into files, 

storing the information comprising the priority information, the audiovisual 

data and the control data at the record carrier. 
25 The playback control program may be recorded at the same information carrier 

together with the audiovisual data, but may otherwise be stored at a separate record carrier or 

in a ROM of the playbackdevice. 



30 These and other aspects of the invention are described in more detail with 

reference to the drawing and with reference to an appendix: "Specification Proposal for a 
Video Disc Play Control Program (PCP)" which is incorporated by reference herein. In the 
drawing: 

Figure 1 shows an embodiment of a record carrier according to the invention, 
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Figure 2 shows an embodiment of a device according to the invention, 
Figure 3 shows an embodiment of a method according to the invention, 
Figure 4 shows relations between several aspects of the invention, 
Figure 5 shows a further embodiment of a method according to the invention. 

5 

Figure 1 shows a record carrier 1 which comprises information organized in a 
plurality of files 2 containing audiovisual data 1 1 and playback control data 12 for 
interactively controlling reproduction of the audiovisual data 11 on a playback device. The 

10 playback control data on the one hand controls playback of the audiovisual data and on the 
other hand allows for user interaction, for example by providing options from which the user 
can choose. In the embodiment disclosed here the files have a file structure as described in 
section 3 of the appendix. Part of the file structure is a file header (File Jieader) containing a 
file identification (FileJD). In an embodiment the audiovisual data maybe contained in one 

15 or more of the following four types of MPEG files. The first type is an MPEG movie file 
(FileJD = 10). This type of file contains a video stream, one or more audio streams and a 
private stream. A second type of file is an MPEG audio file (FileJD =11). This type of file 
contains one or more audio streams, but no video stream. A third type of file is an MPEG 
picture file (FileJD = 12). It contains a video stream with one or more still pictures, but no 

20 audio stream. A fourth type of MPEG fi le (File_ID = 1 3), a so called MPEG show file 
comprising a video stream with one or more still pictures and one or more audio streams. 
Further the audiovisual data may comprise JPEG picture files (FileJD = 20) and bitmap 
image files denoted as BMP in the Figure (FileJD = 21). The playback control data 12 
comprises one or more so called Play Control Program files (PGP, File_ID = 3), which may 

25 include a PCPrfile for startup. Each PCP-file may contain one or more functional blocks FB. 
An FB on its turn contains one or more commands CMD1 , ... CMDn, as described in section 
4 .5 of the appendix. Further the playback control data comprises a Play Item Table file (PIT- 
file, FileJD = 2). The structure of the PCP-file is described in detail in section 3.2 and the 
PIT-file is described in section 3.3 of the appendix. Furthermore the record carrier comprises 

30 a File Record Table file (FRT-file, FileJD = 1) as described in section 3. 1 of the appendix. 
The FRT-file comprises information about all files at the record carrier 1 , such as their size 
and address at the record carrier as well as genera) information about the record carrier. The 
record carrier is preferably a medium which is randomly accessible, such as a disc, as 
described in the appendix, or a card. The medium is for example an optical, a magnetic or a 
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magneto-optical medium. The information at the record carrier 1 further comprises priority 
information, indicating the relative priority with which the files 2 are to be stored in a cache 
memory of the playback device. 

In the embodiment described here the priority information is contained in a 
single file, in this case the FRT-file. For each of the files 2, including itself, the FRT-file 
comprises an entry denoted as "priority" which has a value in the range of 0 to 15. The 
priority information is related to the estimated frequency with which the said data is 
accessed. A high value of priority represents a high estimated frequency. In the embodiment 
described here the control data is comprised in one or more control programs, the PCP-files 
which comprise references to menus, e.g. in the. form of MPEG picture files. Preferably these 
files have a high priority, preferably the highest value (15). 

Figure 2 shows a playback device according to the invention for playback of 
the record carrier 1 described above with reference to Figure 1. The playback device 
comprises read means 20 for reading the data from the record carrier I. The read means 20 
are provided with control means 21 to control the reading of data from the record carrier 1 
upon instructions by processing means 30 for processing the control data. The data read from 
the record carrier 1 is transmitted via a bus 15. The device further comprises a cache memory 
39 for storing data from the record carrier 1 . In addition the device has a process memory 31 
for storing data which is being used by the processing means 30. The device also comprises 
user input means 40, 41 for enabling user interaction. The user input means are for example a 
keyboard or a pointing device such as a mouse. The processing means 30 interactively select 
audiovisual data from the record carrier 1 and have these reproduced by audio reproduction 
means 53, 54 comprising an MPEG-audio decoder 53 and video reproduction means 51, 52 
comprising an MPEG-video decoder 51. The device according to the invention is adapted to 
read priority information and to store files in the cache memory 39 in accordance with this 
priority information. To this end the device reads the priority information from the FRT-file 
and if the cache memory 39 is too small to store all files, the device stores those files in the 
cache memory 39 which have the highest priority value. The processing means 30 comprise 
interpreter means 32 for interpreting commands CMD1, ... in the functional blocks FB of the 
play control program file PCP. The interpreter 32 sequentially interprets the commands and 
writes/reads a plurality of Player API registers, also denoted as Registers, which function as 
an application programmers interface. These Registers and their function are described in 
section 4.3.2 of the appendix. For example upto 1 6 hotspot areas may be defined by writing 
the Registers 128-191. A next PCP-file may be selected by writing its file number in the 
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Register numbered 226. A pi ay J tern, for example an MPEG file may be selected by writing 
an identification of said item in Register 228. Note that most Registers correspond to a 
separate register for writing and for reading. By reading a Register status information 
returned by the executing means 34 may be retrieved For example, if the Register numbered 
5 228 is read a so called play event ID value may be retrieved. The latter indicates a cause for 
ending the playback of the MPEG-file. A more detailed description is given in section 4.4.6 
of the appendix. The interpreting means and executing means of the processing means may 
be incorporated in software on a single processor or may be implemented as different 
processors. The mutual relation of the different files is shown in Rgure 4. When a file 

10 number of a PCP-file is written in register 226, the execution means 34 retrieve the file 
address of said PCP-file fonn the FRT-file. If this file is not already available in the cache 
memory 39, it is loaded from the record carrier 1 into the process memory 3 1. If the Play 
Control Program file writes an identification of a Play-item in the register 228, control is 
passed to the execution means 34. These look up the corresponding filenumber of an 

15 audiovisual file and the entry point within said file in the Play Item Table PIT and have said 
play-item reproduced. The file address of said audio visual file is retrieved from its file 
number by means of the FRT-file. If control is passed to the execution means 34 then 
Operation of the interpreting means 32 is suspended until an event is detected by event 
handler means 35. The event handler means 35 may detect at least one of the following 

20 events, the expiration of a time interval, an input by a user, the occurrence of trigger data in 
the audiovisual data. This is illustrated in Figure 1 of the appendix. A command set Timer, by 
writing a value to Register 252, has the effect that a timer 35 starts to count down from said 
value and that a timer event occurs if count down is completed. A trigger event occurs if a 
trigger detector 37 detects that trigger^data corresponding to a trigger_mask loaded in 

25 Register 249 occur in an MPEG stream which is read from the currently selected file. A user 
may cause an event in several ways. In the first place one or more hot spots may be defined 
by writing a selection or all of the registers 128 to 191 . If the user points to a hotspot, a 
hotspot event occurs. Otherwise a userkey event occurs if a key is pressed which is enabled 
by the userkey_mask. The latter is assigned to Register 250. If the reproduction of the MPEG 

30 file is completed likewise an event, End_ofJFile event, occurs. If an event occurs the event 
handler means 35 enable the interpreter means 32 to continue the interpretation with a 
command (Command #n+l) succeeding the command (#n) at which the operation of the 
interpreter means 32 was suspended. 
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If a file is accessed, the procedure illustrated in Figure 3 is followed. First in 
step SI it is examined whether the file to be accessed is already in the cache memory 39. If 
this is the case, then in step S2 the file is copied from the cache memory 39 into the process 
memory 31. Subsequently the file can be processed in step S3. If the file to .be accessed is not 
available in the cache memory 39 then it is loaded from the record carrier 1 into the process 
memory 31 in step S4. Next it is examined in step S5 whether in the cache memory 39 
enough free space is available to store the file. If the outcome is positive the file is copied 
from the process memory 31 into the free space of the cache memory 39 in step S7.If the 
outcome of the examination in step S5 is negative the program step S6 is executed. Therein it 
is examined whether enough space in the cache memory 39 is available which is occupied by 
files having a lower priority than the file which was accessed. If this is the case than that file 
is copied from process memory 31 into the said space in the cache memory 39 (step S7). 
Otherwise the said file is not copied into the cache memory 39. 

An embodiment of the device according to the invention also includes a 
procedure for loading the cache memory 39 during initialization. Such a procedure is 
described with reference to Figure 5. In a first program step S 10 a priority reference value PR 
is initialized at 15. In a second program step Sll a fiienumber I is initialized at 1. Next in 
step S12 it is examined whether the file with file number I has a priority equal to PR. If this is 
not the case than the procedure continues with step S15. Otherwise the procedure continues 
with step S13 wherein it is examined whether the size of the file with fiienumber I is less or 
equal than the free space in the cache memory 39. If this is true than said file is loaded into 
the cache memory 39 in step S14. If it is not true than the procedure continues with s«ep S15. 
wherein the fiienumber is increased by 1. Subsequently in step S16 it is examined whether 
the fiienumber is less or equal than the total number of files. If this is true than the procedure 
continues with step S12. If this is not true than the priority reference value is decreased by 
one in step S 17. Subsequently it is examined whether the new priority reference value is 
greater than or equal to 0 in step SIS. If this is true than the procedure continues with step 
S 1 1 . If it is false then the procedure is completed. 

It is remarked that the scope of protection of the invention is hot restricted to 
the embodiments described herein. For example, while an embodiment of the apparatus 
according to the invention is described which comprises detection means to detect which type 
of record carrier is present, an other embodiment comprises input means which enable a user 
to provide that information. The apparatus may comprise recording means for recording an 
information stream on the record carrier in addition to the reading means. Neither is the scope 
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of protection restricted by the reference numerals included in the claims. The word 
'comprising* does not exclude other parts than those mentioned in a claim. The word *a(ny 
preceding an element does not exclude a plurality of those elements. The invention further 
resides in each new feature or combination of features. 
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Specification Proposal for a 
Video Disc Play Control Program flPrP^ 



By Erik Schylander 
version 3-Nov-99 11:43 



A Play Control Program (PCP) is used for the user navigation when playing the disc The user 

^TZTo^^T 1 ^ menus - 11 is app,icab,e to any 2K sector addre - ble 

In the current VCD and SVCD specifications a Play Sequence Descriptor (PSD) file is used 
tor the PCP with a fixed syntax and semantics. It has the drawback that it is static (pre- 
determined)^ can not adopt to the input of user. No conditional testing or computations are 
ybaCk iS P r °S rammed b y ^oried Play Lists and Selection Lists that define 
the MPEG streams to play. In SVCD an extension was introduced called Command Lists 
which allowed conditional testing and some limited computations. 

This proposal is based on about the same concept, but without using Play Lists or Selection 
Lists. It also supports event handling triggered by a MPEG stream playback point a timer or a 
user input. 

This is also very different from DVD, where the control and navigation data is stored in the 
MPEG stream, which makes the authoring and testing very complicated. 



Revision history 

rev#Id - 26/10/99 NVRAM size allocated by Disc Jnfo, and Fixed location at Reo[0J. 
Fixed type errors, updated figure 1 , outline changes 

rev#2a - 27/10/99 Simplified Player registers to avoid MSB, LSB bytes (Hotspots.OGT. 
Audio_streaim), and reallocated register numbers. 
Added JPEG and BMP file types values. 
Added as extension OGT rendering in a hotspot area. 

Rev#2b - 1/1 1/99 Changed name of DRT toFRT, and PIN to PIT to use more correct wordino 
Added Player States (stopped, playing, paused, scanning). 
Added field in MPEG info record for PlayingTime. 
Added field in MPEG info record for average sector (bit) rate. 

Rev#2c- 2/11/99 Filled in Error codes 

Added place holders for Systems Overview 

Cc: D. de Jong, CP&T. 
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General 

Normative References 



The following Standards contain provisions, which, through reference in this document ai 
used this document. 



IS0646 
ISO9660 

ISO/IEC 11172-3:1993 


7-bit coded character set for information interchange 

Volume label and file structure (ISO9660) of CD-ROM for information interchange 
Information technology-coding of moving picture and associated audio for digital 
storage media up to about 1 ,5Mbit/s Audio (MPEG 1 ) 


ISO/IEC:13818-l r 2,,3 
2 nd edition:1996/1997 
ISO/IEC: 10918-1 
IEC:13346 


Generic coding of moving picture and associated audio information (MPEG2); the 
1 997 edition shall apply for audio coding 
Digitahcompression and coding of Still Images (JPEG) 
UDF 2.0 as defined by OSTA (Universal Disc File system) 



Conventions 

Bold terms are defined in this document 
Values and comments are written in italic. 
Hex values are preceded by a $ character 
Binary values are preceded by % character 
Strings are within double quotation marks, as 



Abbreviations and general definitions 
The following abbreviations are used in this document. 
# or ## Abbreviation for " Number of M . 



Album 
Album JDD 
Audio stream 

Bitmap image 



CLUT 

FRT 

Hotspot 



Hotspot area 



An Album is a collection of discs with the same AlburnJD. 

An uniquely value that identifies all discs belonging to an Album. 

The MPEG stream can contain one or more audio streams numbered 1 to 

max. It is optional to support surround sound in the Extended stream. 

An image representation where each pixel is represented by on or more 

bits. These bits represent different color values in a color lookup table 

(CLUT). 

A Color Look-Up Table, defining a color value (RGB) for each entry. 
File Record Table, see 0 

A Hotspot is defined by the ID number and the area coordinates on the 
screen. Hotspots are used for user interaction on the screen, so a user can 
select a hotspot (by cursor or pointer control) to interact with the PCP. The 
selection of a Hotspot generates a Userjnput event. It can be used by 
(computer) playback systems that use pointing devices for user interaction, 
or for systems that can highlight selected areas. The area within the 
indicated co-ordinates should be highlighted. The player can chose frame 
thickness and color. Such highlighting is recommended to have two views, 
one when pointer inside area or one when selected. If more hotspot areas 
contain the point selected, (in the case of overlapping selection areas) then 
the selection area with the lowest Selection Numberts selected. 
The hotspot coordinate area defines a rectangular Selection Area on the 
screen. A scaled coordinate system is used such that the extreme upper left 
screen co-ordinate is 0,0 and the extreme lower right screen co-ordinate is 
255,255. 
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JPEG 
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OGT 



PIT 
PCP 



Playback 
device 

PS 
RT 

RAV 



For I-field pictures, i.e. when a video frame is encoded in the form of two 
fields, the sector containing the start of the I-picture with the first of both 
fields shall be referred to (even when the 2 nd field is closer to the expected 
grid). 

Joint Photographic Experts Group, See ISO/IEC 10918! 
Least significant bit. 
Least Significant Byte. 

Moving Picture Experts Group, see ISO/IEC 1 1 1 72. 

A MPEG-2 Program Stream, that can contain a video stream, zero or more 
Audio streams and a MPEG private stream. 

A MPEG private stream that contains the OGT data and Trigger_data 

Most significant bit. 
Most Significant Byte. 
Not Applicable. 

A Non Volatile memory in the Playback device to permanent store a part of 
the Global variable registers for a disc, and shall be recalled when a disc 
belonging to the same album is played again. This is an optional feature of 
the playback device, unction that is called when a register is set. The 
playback device shall uniquely allocate the NV-RAM memory for each 
disc by using the Album ID as unique identification. 

Data that define the Overlay Graphics and Text function for the MPEG 
decoder. 

The MPEG stream can contain in the Private stream up to 8 OGT channels 
numbered from 1 to max. 

Play Items Table, a list of all MPEG file entry points (access sectors). 
Playback Control program. The program is recorded in a form that is very 
compact and easy to implement. If s compiled and optimized during the 
authoring process. The playback device (player) uses the PCP for 
navigation and playback selection. 

A compliant device that contains a disc loader with optical pick-up unit and 
servo controller, MPEG_decoder, and Playback processor with user I/F, 
player control and PCP interpreter. 

A MPEG Program Stream, a collection of MPEG Elementary streams. 

Real Time, a classification for (MPEG) files that has to decode data for 
Real Time output 

Read and Write, used to define the characteristics of the PCP registers. 



Data types and structures 



Bit 


A binary dipit that can have value %0 or %1. Bits are numbered as Mnumbrr 


n-bit data 


A stream of n number of bits, where the first bit =b#/i-i are! the last bit=b#0 (msb) 


True 


A logical state of a n-bit data value, where one or more bits = %1 


False 


A logical state of a n-bit data value, where alt bits = %0 


Byte 


A 8-bit data value, that represent the values 0..255 



WO 0iy35416 



PCT/EP00/11114 



Zerobyte 
Reservedbyte 
Character 
Digit 



A bvte with the value of 0 ($00) 
A Zcro_byte reserved for future use 



A byte repres enting a Character, coded as ISQ646 
One of the Characters "0 123456789" 



Number 

N-byte integer 



A positive v alue represented by a String of Digit 



A signed value of N bytes recorded in Ts complement format 



An unsigned value of N bytes 



Item 

<Item> ~ 
Item_type 


AnydataasanarrayfCUajr bvte} of byte, where the ltem_ size, slag hvt^h " 

One of the following data types: " ~~ : — : ' 

Boolean: False.True 
Byte 

Character 
N-byte integer 
N-byte word 
String[] 
Arrayf] 
Record 


Array[ 0 Uutjtem ] of 

Itenr type 

Index 


hem "t^e 011 * COnSCCUlIVC ,ndcxcd ilems * from 0 to »«t item, of the same 


String! length) 


1 A n-bvte word, used to indicate or reference an item in an array 
an array of up to max. length number of character's. The string is padded with 
Zero.bvte s for not used characters. An emotv sirino stains onlv Zero hvt^c 


Fieldjtem 


A data smjaure defined as " S= " J '■ 

Struc( Item name <Jtem name> of hem ryp* ) 


Record 
Table 


A data structure defined as 1 — 

Strucf Reldjtem<; Field Jtem> } 

These items form a block of consecutive bytes - recorded in «*»»Rn.ir,i ^ rr 

An Arravl 0.. last record ) of Record " ■ ~ 



System overview 

This is a disc system to present full motion pictures with associated audio by using any ROM 
(2K addressable sector) disc format. The system uses the ISO/EEC MPEG? standard 
definitions to compress the video, still picture and audio information for full screen TV 
qua ity pictures together with associated high quality audio. The disc also contain hi°h 
quality still pictures (menus) and a Playback Control Program file for navigation and* 
playback control of the disc. 

Player Reference Model 

The system consists of a disc and a compliant playback device (player). 



Disc Reader Module 



MPEG decoder 

Overlay Graphics and Text (OGT) 
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Cache Memory 

This is an optional feature in a playback device. To access a file in a player can take up to 1 
or 2 seconds, but by storing frequently used files in a Cache RAM memory the access time 

T^tt 3 !f? G f t " * ad - fOT the f,rSt time ' ** P la y faack *"*» c *> 

to store the file in the cache depending on the priority value and how full the cache is The 

pnonty value gives an estimated likelihood that the file will be used again. This is specially 
useful for Menu still picture files, which normally have a size of 1-200KB The cache 
memory need to be 1MB or more, but with the falling memory prices this will only add a 
marginal cost to a player. ; • 



Disc structure 



Disc 



Sector 

Sector addres 



An Array \Q~last_seaor\ of Sector. 



An AiTayr(L2 047] of Byte. User data is recorded in the Sector. 



File structure 


*rte 

FHe_start address 


User bytes are stored on the disc as an Array[0 lasijbyte] of byte, indexed by 

Me_byte_position. The File is recorded in the consecutive sectors as defined by 

Dfcc[file_start_ a ddress - ^cnd.address] of Sector. The last sector is padded 
with zero byte*. ^ 

The sector_address value of the first sector of a file, 


File end address 
FOeZsize " 

File byte position 


The sector address value of the last sector of a file. 

A 34>yte word value representing the number of Sectors recorded on the disc that the 
file occupy. The value is = (File_*id_address - FUe„startjaddress+ 1). Note that the 
number of bytes in the fde is a (File size » Sector sizcl. 


Structured Jile 


An index of a byte in FilefO last bvte]. 

A file starting with a File_header, followed by an Array of Items, indexed from 0 to 
lasutem. The item structure is depending on FileJD value, and is defined below for 
each specified FileJD. 

The file structure = strod Fde header: arrayf 0..lasr item] of Item J 


FOe.header 


A record that contains informauon about the structured file defined as Strucl 
FrteJD, ]tem_.oOs, ltem_size t 1 tem_ count of 2-byte word; 
<, Info of Array \0„last tote] of byte > ). 


FileJD 

ltem_offs — — 
ltem^size 


A word identifying a specific file. Specified file JD*s are: 

0 = unspecified file 

1 = File Record Table (FRT) file 

2 = Play Item Table (PIT) file 

3 = Play Control Program (PCP) file 

10 = MPEG movie file 

11 = MPEG audio file 

12 = MPEG picture file 

13 = MPEG show file 

20 = JPEG picture file 

21 = Bitmap image file (3MP) 
Other values are reserved for future use 

A 2-byte word for the file byte_position of the first item with index = f) 
A 2-bvte word for the number of bvtes an Item contains. 



15 



WO 01/35416 



16 



PCT/EP00/11114 



ltem_count 



Info 



A 2-byte word for the number of items in the file = (last item* 1 V 

An nnrirmal fi«»M rn rtnro nu^;^. :_r : . 



Aii optional field to store specific infoitnation. 



File Record Table (FRT) file 

A structured file that contains a Table of File_directory_records indexed by a 

c E^T"? ~ The rccord contains information about where the files are located on the disc 
5 The default File_number of this file = 0. 



UDF file name 
FHe_header 


" = "FRTJJIN" -i 

The filejieader is defined as: 
FDe_lD=i 
ltem_ofis = 24 
Itero_size= 16 

ltem_count = number of File_directory records 
Info = Disc Info of 1 6 bytes 


Disc_info 
Album^ID 


«j w ** wiuoiu tuiuj iiuiLiuii duum me disc, denned as Struct 
AlbumJD = 4-byte word; 
DiscJD = 2-byte word; 
Disc_count = 2-byte word; 
NVRAM_si2e = 1-byte word; 
Reserved =7 Zero bvtes). 


DiseJD 
Disc_count 


A unique number that is the same for all discs that belong to the same Album 

A sequennal number starting from 1 that identifies the sequential order of the disc in 

the Alburn. 


NVRAM_size 


A 2^by te word that contains the total number of discs in the Album. " 
A 1-byte value that defines the number of Global Variable registers. Reg[0 
NVRAM_size-ll that shall be permanently stored into the NVRAM of the playback 
device when the discis stopped by an EndO or GotodtecO function. At startup of a 
disc the NVRAM data shall be loaded into the same specified Global Variables 
again. If the NVRAM^stee = 0 then no acuon required. The playback device support 
of this NVRAM feature is optional ■ 


File_directory_record 
FUe_address 


A 16 byte record of 4 fields that contain file information data, defined as- 

Strucf Fdejiddress, Fde_size of 3-byte word; FileJD of 2-byte word: File info of 

8 byte record). 

The File ID = the Fil^ m v^Ida r\f j 


Fifejnfo 


A 3-byte word sector address of the first sector of the file 

A 8 byte record that contains information about the file, defined as Struct 

Priority = 4-bit word ( 0..15); 

R*striction_category = 4-bit item. (Lb.d) 

Video.type = 8-bit item; {PAL/NTSQJull- /sub-picture) 

Aodio_streams = 8-bit item; (see 0 and 0) 

OGT_streams - 8-bit item; (see 0) 

Playing^time = 2 byte item; (see 0) 

Sector_rate = 1 byte item, that for RT files, indicates the average number of sectors 
(in units of 16K or 8 sectors) per second. For non RT files this value is 0. (see 0) 
This value is used by the Playback controller to estimate the entry point into a MPEG 
file for a scan Junction or jump to time (seconds) Junction, by calculating the sector 
offset as (Sector jrate * time). 
Reserved =1 Zero byte }. 


Priority 
File.number 


A value 0..15 mat indicates the frequency distribution a file is expected to be 
accessed, where the value of 15 is used for the most frequent files, e.g. Menu's. This 
value can be used to support a cache memory feature in the playback device to 
improve the playback performance, see 0. 

A 2-byte word Item index of the File directory record in the FRT file 
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supported, those that has been stored in the NV-RAM.. 
At read return the set value. 
At write set value. 


32 63 


Parameters 


l hese 32 registers, indexed 32 to 63, are used for passing parameters to a FB 

ftmction, and for returning parameters from a FB function. Before calling a FB 

function intermediate results should be saved in the local FB variables 

At startup the variables should not be seu and shall keep its values during the 

change of a disc. & 

At read return value. 

At write set value. 


64.. 95 


Local FB variables 


Up to 32 registers, indexed 64 to 95. can be allocated to be used locally by the 

called FB function or the error handler Thnv vannKUc -,ti~.~»~i w 

■ wjv* Huiiuiu. i iicoc vanaDies arc allocated by setting 

the FB var.sizeregister. Allocated local FB variables shall be saved in memory 

beforethe new FB function starts. Local FB variables of the calling FB function 

shall be restored from memory by the ReturnO function. Allocated variables 

shall be set to 0. 

At read return the set Value. 

At write set value. 


96.. 
127 


reserved 


Reserved for future extensions. 



Player API registers, R[128~2S5] 



Index 

128 .. 
143 


Register 

Hotsporarea top 
ID = #128 _ #143 


Description " " " : 1 

At startup the register shall be set to -1 if Hotspots are supported by the 
playback device else it shall be set to -2. 

At reatf return the vertical position of the top line of the hotspot(#ID) selection 

^ 7! 1?8 J43arc roaPP" 1 U> register values 128 143. Ifthe hotspot 
is disabled then return -L See 0 

At write set the top position for the hotspot(#ID). If this register is set to -1 then 
the hotspot is disabled. 


144 

159 


Hotspot_area_bottom 
ID = #128 _ #143 


At startup the register shall be set to -1 if Hotspots are supported by the 
playback device else it shall be set to -2. 

At read return the vertical position of the bottom line of the hotspot(#ID) 
selection area. ID values 128 143 are mapped to register values 176 191 If 
the hotspot is disabled then return - 1 . See 0 

At write set the bottom position for the hotspotf#ID). If this register is set to -1 
then the hotspot is disabled. The hotsoot bottom value shall be>- top value 


160.. 
175 


Hotspot_area left 
ID = #128 -#143 


At startup the register shall be set to .1 if Hotspots are supported by the 
playback device else it shall be set to -2: 

At read return the horizontal left most pixel position of the hotspot(#ID) 
selection area. ID values 128 ~143 are mapped to register values 19> ->07 If 
the hotspot is disabled then return -1. See 0 

At write set the horizontal left most pixel position for the hotspot(#ID). If this 
register is set to -1 then the hotspot is disabled. 


176 
191 


Hotspot.area right 
ID = #128 #143 


At startup the register shall be set to -I if Hotspots are supported by the 
playback device else it shall be set to -2. 

At read return the horizontal right most pixel position of the hotspot(#ID) 
selection area. ID values 128 ..143 are mapped to register values 208 223 If 
the hotspot is disabled then return - 1 . See 0 

At write set the horizontal left most pixel position for the hotspot(#lD) If this 
register is set to -1 then the hotspot is disabled. The hotspot right value shall be 
>= left value. 


192 .. 

223 

224 


reserved 





225 



FBaddress 



At read return the current FB local variables size. 
At write call t he FB local variables meroory(size) function. See Q. 
At stanup the register shall be set to 0. 
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• MPEG Audio only with no pictures or video. 
If a Play Item includes one or more still pictures, the last picture is displayed until it is 
replaced by a new Play Item. 


Access_point 


A 3-byte reference address to a MPEG_file sector that contains the beginning of a 
Mreu I -picture or tor a MrisG audio file the beginning of a audio frame. These are 
the entry points where the PCP program can start playing in a MPEG file. 


Trigger_point 


A 3-byte reference address to a MPEG_file sector that contains Trigger.data stored 
in the Pri vate Stream. When the playback_device is playing a MPEG Jile and passes 
a Trigger.point then it should check if a Trigger eventf) function should be called. 


Trigger_data 


A 16-bit data value in the MPEG private stream, which can be filtered by a 
Trigger_mask to decide if a Trigger_eventO shall be called. 



Play Control Program (PGP) 

The PCP contains the navigation structure of the disc. The PCP is stored in PCP files. The file is divided into 
functional blocks called FB. At startup of the disc the PCP file with File_number = play, the PCP interpreter 
starts to interpret the first FB at address = 0, and continue until an EndO function is called. ' 

PCP file structure 



Command 


A 5-byte item that contains the PCP interpreter instruction code. Commands are 
referenced from 0 to last Command in the FB. 


Comma nd_irid ex 


A 2-byte word ltcm_index in a FB. The Command Jndex is = 0 for the first 
Command in a FB. 


FB 


A block of consecutive Commands, that represent a FB function () that can be called 

by setting the FB_address register. 

The size of a FB block shall be less than ?? Commands. 


FB_address 


A 2-byte word Itemjrtdex of the first Command in the FB. The address of the first 
FB in the PCP file = 0. 



5 



PCP Interpreter 

The PCP interpreter shall interpret and execute the Command instructions in the FB. These 
Commands shall be interpreted in sequential order one by one, until a ReturnO or an other 
function is called. If an error is detected the Error_handler shall be called. Most Commands 
10 will only be executed if a specified Command condition is fulfilled. 

The PCP interpreter is easy to implement with a standard micro-controller, as it needs only 
to handle three simple type of operations: 

• Read / Write of variable and register data 

• Arithmetic operations on variables 

15 • Command interpreter sequence management 

PCP structure 

The relation between the different PCP data elements are shown in the figure below. 
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PCP00002file 


PCP00Q03 file . PCPrmnnn file 






FBOOOO FBxxxx 


// lastFB 



Command 


Command 


IT 


Command 


0000 


0001 




last 



PCP Interpreter reference model 

The PCP interpreter reads the commands in the EB one by one and executes the command 
instruction as defined in section 0. The command reads and writes data into the Variable 
Array. Values written into the register variables shall be stored in memory. If a value is 
written into the Player register part then a specific function0 is called and shall be executed 
before the next command is interpreted; See the figure below. 



Variable Array Reg[q 



Command 
nnnn 





PCP 


► 


interpreter 




Register variables 

Reserved variables 

Player register API 
Read status 
Write commands 



10 FB program flow structure 

The control flow structure between FB's, PCP files, and discs is shown in the figure below. 
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Start 



Call() 



Call() 



FB 00 


^Return(£ 


FB XX 


^Return(£ 


FByy 








4 > 




A 



Stop() 



Player States 



The MPEG player in the MPEG device can be in one of the states as described below. These 
states are important for the Play() function, see 0 

5 



State 


Description 


Stopped 


The MPEG player stopped decoding the MPEG stream, either bv a PlayO command or by an 
End_o£_File event The last MPEG picture should remain on the screen. 


Playinc 


The MPEG player is active decoding the current MPEG stream. 


Paused 


The MPEG player can be paused during Playing directly by the user. It does not effect the 
Interpreter as it is halted waiting for an EventO- When the user wants to continue the Player 
shall return to the Playing state. 


Scanning 


The MPEG player can scan the MPEG stream (file) forward or reverse during Playing 
directly by the user. It does not effect the Interpreter as it is halted waiting for anEventf). In 
the MPEG info record there is a field that gives the average bitrate to guide the player on 
how many sectors to jump per second. When the user wants to continue the Player shall 
return to the Plaving state. 



PCP registers 

The PCP interpreter uses an array R[0-255] of 2-byte (16-bit) registers, that contain 
10 variables and player registers that functions as an API for the PCP interpreter to interface 
with the player functions and MPEG decoder. The PCP_registers can be read and written to 
by the PCP interpreter. The 256 registers are indexed from 0 to 255. The player shall set the 
defined player registers reflecting the current player status to be read by the PCP interpreter. 
At start up of the disc the default player values should be used. Some players allow the user 
15 to change the default values. The PCP can control the player by writing a value to a R/W 
player register, and the player has then to execute controls that would generate the same 
status. Note that a R/W player register actually consists of two different registers, one for 
read of the player status, and one for giving a command to the player. When the player is 
busy executing a register command, then these values could be different. 

20 Variable registers, R[0..95] 



Index 


Register 


Description 


0„31 


Global variables 


These 32 registers, indexed 0 to 3 1 . are used for storing global accessible 
variables. 

At startup these variables shall not be set except if the NV-RAM function is 
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supported, those that has been stored in the NV-RAM.. 
At read return the set value. 
At wrhe set value. 


32 .. 63 


Parameters 


These 32 registers, indexed 32 to 63, are used for passing parameters to a FB 

function, and for returning parameters from a FB function. Before calling a FB 

function intermediate results should be saved in the local FB variables. 

At startup the variables should not be set, and shall keep its values during the 

change of a disc. 

At read return value. 

At write set value. 


64 ..95 


Local FB variables 


Up to 32 registers, indexed 64 to 95, can be allocated to be used locally by the 
called FB function or the error handler. These variables are allocated by setting 
the FB var_size register. Allocated local FB variables shall be saved in memory 
before the new FB function starts. Local FB variables of the calling FB function 
shall be restored from memory by the ReturnO function. Allocated variables 
shall be set to 0. 
At read return the set value. 
At write set value. 


96.. 
127 


reserved 


Reserved for future extensions. 


Player API registers, R[128..255] 


Index 


Register. 


Description 


128 .. 
143 


Hotspot area top 
ID = #128. ~ #143 


At startup the register shall be set to -1 if Hotspots are supported by the 
: playback device else it shall be set to -2. 

At read return the vertical position of the top line of the hotspot(#ID) selection 
area. ID values 128 ..143 are mapped to register values 128 - 143. If the hotspot 
is disabled then return -1. See 0 

At write set the top position for the hotspot(#ID). If this register is set to -1 then 
the hotspot is disabled. 


144.. 
159 


Hotspot_area_bottom 
ID = #128 ~ #143 


At startup the register shall be set to -1 if Hotspots are supported by the 
playback device else it shall be set to -2. 

At read return the vertical position of the bottom line of the hotspot(#ID) 
selection area. ID values 128 .. 143 are mapped to register values 176 ... 191. If 
the hotspot is disabled then return -I. See 0 

At write set the bottom position for the hotspot(#ID). If this register is set to - 1 
then the hotspot is disabled. The hotspot bottom value shall be >= top value 


160.. 
175 

\ 


Hotspot_area left 
ID = #128 #143 


At startup the register shall be set to -1 if Hotspots are supported by the 
playback device else it shall be set to -2. 

At read return the horizontal left most pixel position of the hotspot(#ID) 
selection area. ID values 128 ..143 are mapped to register values 192 207. If 
the hotspot is disabled then return - 1 . See 0 

At write set the horizontal left most pixel position for the hotspot(#lD). If this 
register is set to -1 then the hotspot is disabled. 


176 .. 
191 


Hotspot area right 
ID = #128 „ #143 


At startup the register shall be set to -1 if Hotspots are supported by the 
playback device else it shall be set to -2. 

At read return the horizontal right most pixel position of the hotspot(#ID) 
selection area. ID values 128 ..143 are mapped to register values 208 223. If 
the hotspot is disabled then return -1 . See 0 

At write set the horizontal left most pixel position for the hotspot(#lD). If this 
register is set to -1 then the hotspot is disabled. The hotspot right value shall be 
>= left value. 


192.. 
223 


reserved 

# 




224 


Locals_size 


At startup the register shall be set to 0. 

At read return the current FB local variables size. 

At write call the FB local variables memorv(size) function. Sec 0. 


225 


FB_address 1 


At startup the register shall be set to 0. 
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At read return current FB_addresZ ~ ' 

. At write eallthe FB(address) function. Sec 0. 


226 


FDeJtf umber 


At startup the register shall be set to 2. (she first PCPfile) 
At read return trie File^Nuinber of the current PCP file. 
- At write call the goto PGPHHig Nnmhor) function? See 0. 


227 


Disc_Number 


At startup the register shall be set to 1. 
Atread return the Disc_Number of the current disc. 
_ At write call the goto DiscfDisc Number) function. See 0. 


228 


Play_item 


At startup the register shall be set to -1. 
At read return the play event ID value. 

At write call the play(PIN) function. See 0. ' 


229 


MPEGJileJnfo 


At stanup the register is set to -i. 

At read return current MPEG file number if the last write call was successful 
else return -1. \ 
. At write call the MPEG file infoffile numh^ function. See 0 


230 


Playing^time 


At startup the register is set to 0. 

At read return the playing time (in seconds) of the current MPEG file updated 
by the MPEG_fileJnfo function. . 
At write do nothing. 


231 


OGT.channels " 


At startup set to 0. 

At read return the number of current available OGT channels of the curren! 
MPEG file updated by the MPEGJileJnfo function. Sec 0. 
At write do nothing. 


"232 


OGT_seIect 


At startup set to 0. " " " " 

At read return the current selected OGT channel. If OGT disabled then return 0 
At write call the OGT^selectfchanneD function. Sec 0. 


233 


Audio_streams 


At startup set to 0. 

At read return the number of current available Audio streams of the currem 
MPEG file updated by the MPEG Jilejnfo function. See 0. 
At write do nothing. 


"234 


Audio_select 


At startup set to 1. 

At read return the current selected Audio_strcam number. If Audio disabled 
then return 0. 

At write call the Audio_select(stream number) function. See 0 


235 


Audio_mixirtg 


At startup the register sei to playback device defauh value, {stereo-3) 
At read return the current Audio mixing setting 

At write call the Audio, mixing(data) function. See 0. 


236 


OGTJmage 


This is an optional extension. 

At stanup the register shall be set to -1 if OGT rendering is supported by the 
playback device else it shall be set to -2. 

At read return the current File_Number of the image file. If no imace displayed 

then return -1. If this function is not supported then return -2. 

At write call the OGT rendering function, see 0 


237 .. 
248 


reserved 


Reserved for future extensions . 


249 


Trigger_mask 


This register is used to filter the Trigger_data in the MPEG stream to define if a 

trigger event shall occur. See 0. 

At startup this register is preset to -1 (SFFFF). 

At read return the current trigger mask. 

At write set the Trigger_mask. If the register is set to 0 then the Trioppr 
funcuon is disabled. 


250 


Userkey_mask 


This register is used to enable and filter the User keys. Each bit represents one 
ui uic ii me on is set men tne Key is enabled, else it s disabled. 
At startup this register is preset to -1 (SFFFF). 
Auead return the current mask. 

At write set the user key mask. Bit#0 represents the user key with number = 0 
and so on until bit #15 that represents the user key with number = 15. If the 
rceister is set to 0 then all user kevs are disabled 


251 


lnput_data 


This register returns the last pressed User key number or selected Hotspot ID 
number. For user kev values see 0. and for Hotspot ID values see 0. 

.j 1 
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At startup this register is set to -1. 

At ip^ rctara the current Input_data (User key.or Hotspot number). 

At write reset the Input^data to 0. If the value is m the range 128.. 143 then also 

mgnngnttnc corresponding hotspot area else no hotspot shall be highlighted. 


252 


Timer_data 


At startup the itgi^ shaU be set to 0. • 
At read return the current Timer value ( in units of 1/10 sec ). 
At write call the Timerfstart time) function. See 0. 


253 


NVRAM 


^1 *uuwp uic register snan oe set to the NVRAM_size value in the Disc info 
record. 

At read; If no Global registers could be restored form the NVRAM then return 
0, else return the NVRAM_slze value. 
At write no action. 


254 


Error Jiandkr_b)ock 


At startup the register is set to -1. 

At read return currcntError handler address. See 0 

At write set the location of the PCP_bIock to execute by the PCP interpreter 
when an Error has been detected. 


255 


Error_code 


At startup the register isrset to 0. ' 

At read return current Error_code. See 0. 

At write the Error code wilTbe reset to 0. 



™> / ~ / ~ . w . — ****rwva mr nmire use. operations with reserved 

registers, shall generate an error. 

PCP Player (API) functions 

The Playback device shall support the following functions. 
FB local variables memory ( size ) function 

litis function is called when the FB var_size register is set. It shall allocate the number of requested local FB 
variables m memory. The total memory is limited to 256 variables (512 bytes), so this funcuon is to optimize the 
memory usage handling by the PGP interpreter. Up to 32 variables can be allocated for each FB function. The size 
value is reset to 0 when a new FB function is called, so the register must be set to I -32 before local FB variables 
can be used, else an error will be detected. 

FB( address ) functions 



Value 


Function 


Description 


-1 


ReturnO 


Continue to interpret the Command following the Command that called the FB 
function or error handler. 


0 


ResetO 


Clear the Local Variable stack, and the Return stack. 
Start interpret the first FB at FB address = 0. 


nnnn 


FunctionO 


If nnnn is a valid FB_address then call the FB function at address » value. 
Set the local FB variable size to 0. 


else 


ErrorO 


Generate an Error 



Goto JPCP(FHe_number) function 



Value 


Function 


Description 


2 


RestartO 


Load default FCP file with file.number = 2. Clear the Local Variable stack, and 
the Return stack. Start interpret the first FB at FB address = 0 


nnnn 


Goto.PCPO 


If nnnn is a valid File_number for a PCP file, then load the FCP file with 
file_number = nnnn. Clear the Local Variable stack, and^the Return stack. Start 
interpret the first FB at FB address - 0. 


else 


ErrorO 


Generate an Error 
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Goto_Disc(Disc_number) function 



Value 


Function 


a _ . l^glZIZ! Z v «*u^ <«> UCimCU DdQW 

Description 


0 


EndQ 


A runcuon that ends the PCP playback (interpreter execution) and returns 
control to the playback device. 


1 

Disc_coun 
t 


GotoJDiscO 


Stop playing current disc. Change disc to a disc with this Disc number Stan 
playing the disc. Note that the Global variables shall not change values during 
the disc change. 


else 


Error 


Generate ah Error 



Play() function 

This functio n is called by setting the Playjtem register with a value as defined below. 
Value | Function 1 Description ~~ ' 



-1 



Function 



Stop 



If the Player was Playing then the MPEG decoder shall be 
stopped and the last MPEG picture shall remain on the 
screen. 



PIN 



Play 



else 



Error 



If PIN value is valid and the player was Stopped then the 
playback device shall start playing the Play _Item indexed 
by the value in the play.item register. The PGP interpreter 
will wait to execute the Command until a play_event() has 
occurred. 

If PIN value is vaJid and the player was Playing then 
continue playing and halt the interpreter to wait for a 
Play_eventQ» 



Generate an Error 
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Figure 1 Play() function program flow 
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Play_eventO 

A Play_event can only occur during the PlayO function, and the corresponding 
pIay_event_ID vaJue shall be returned in the Playjtem register. The play.events are listed 
below: 



Play_even 
tID code 


PIay_event 


Description 


-1 


End_of_fiIe 


An event called from the MPEG player, to mark that the 
player has reached the end of the MPEG file! 


-2 


Timer_terminate 


An event called from the player controller, to mark that the 
timer has reached the time = 0. 


-3 


Trigger_point 


An event called from the MPEG decoder, to mark that a 

specific point in a MPEG_file has been passed during 

playback. The event shall be called if the logical result of 

(MPEG triggerjiata & Trigger_mask) = True. 

It is possible to use different kind of triggers by setting the 

msb bits as selectors and the lower bits as a trigger 

number. 


-4 


Userkeyjnput 


A function called from the player controller, to mark that a user key has 
been activated by the user. The event shall be called if the User key was 
enabled by the userkey mask 


-5 


Hotspot_select 


A function called from the player controller, to mark that a hotspot has 
been selected by the user. The event shall be called if the hotspot was 
enabled by valid area coordinates. 
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MPEG file info function 

This function is called when the MPEG_file_info register is set to a file^number of a 
File_directory_record in the FRT file. The Playing_time, OGT and Audio.stream 
registers shall be set according to the Filejnfo stored in the Rle_direetory_record This 
register shall return 0 if the file_number is not valid or the File_ID o 10 (MPEG file) else 
it shall return -1. 

OGT_select(channeI) function 

This function is called when the OGT_select register is set. Select the OGT channel to the 
set channel. If set to 0 then disable display of OGT. If set to an invalid value then return 0 
(disable). 

Audio_select( stream number ) function 

This function is called when the Audlo_select register is set. Select the Audio stream to the 
set number. If it is set to 0 then disable (mute) audio. If it is set to an invalid value then return 
0 (disable). 

Audio_mixing( data ) function 

This function is called when the Audio_mixing register is set. Set the Audio mixing as 



Data 
value 


Audio mixing setting description 


0 


Audio mute 


1 


Left channel only 


2 


Righi channel only 


3 


Stereo - 


4 


Surround sound 


else 


Do nothing 



Hotspot() function 

The hotspot function is used for user interaction on the screen, so a user can select a hotspol 
(by cursor or pointer control) to interact with the PCP. The ID number (128 143) of a 
selected hotspot shall be stored in the Input_data register. The area within the indicated co- 
ordinates (top, bottom, left, right) shall be highlighted. Highlighting can be done e * by 
drawing a frame around the selected hotspot area, or by changing the contrast within°the 
selected area. The playback device can chose frame thickness and color. Such highlighting is 
recommended to have two views, one when the pointer is inside the hotspot area or one when 
the hotspot is selected. If more hotspot areas contain the point selected, (in the case of 
overlapping selection areas) then the selection area with the lowest ID number shall be 
returned in the Input.data register. A hotspot is enabled when all area values are valid 
defined by (all values >=0 and within the screen area, and bottom >= top, and right >= left) 
If a hotspot is disabled then all hotspot area registers shall return -1 . A hotspot area can be 
highlighted by writing a valid ID number for an enabled hotspot in the Input.data register 
If the lnput_data register is set to an invalid value then it shall return -1 . & 

UserkeyO functions 

The UserkeyO function is initiated by an user interaction pressing an enabled key The key is 
enabled if the corresponding Userkey_mask bit is set to 1 . The function returns the Key 
number value in the lnput_data register as defined in the table below: 
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Key 


Userkey_mask bits 


User Key 


number 


(msbJsb) 


description 


0 


%0000 0000 0000 0001 


Numeric key 0 


1 


%0000 0000 0000 0010 


Numeric key 1 


2 


%0000 0000 0000 0100 


Numeric key 2 


3 


%0000 0000 0000 1000 


Numeric key 3 


4 


%0000 0000 0001 0000 


Numeric key 4 


5 


%0000 0000 0010 0000 


Numeric key 5 


\j 


aHAAAJ UUVAJ U1UU UUUU 


Numeric key 6 


7 


%0000 0000 1000 0000 


Numeric key 7 


8 


%0000 0001 00000000 


Numeric key 8 


9 


%0000 0010 0000 0000 


Numeric key 9 


10 


%0000 0100 0000 0000 


Upkey T 


11 


%0000 1000 0000 0000 


Down key i 


12 


%0001 0000 0000 0000 


Left key <- 


13 


%0010 0000 0000 0000 


Right key -> 


14 


%0100 0000 0000 0000 


Enter key J 


15 


%1000 0000 0000 0000 


Tripper key • 



Timer(time) function 

This function is called when the Timer_data register is seL The timer is started when the Timcr_data register is 
set to a value that is >0 (in units of 1/10 sec), and decrement the register value each 1/10 second until it reaches 0, 
when the timer is stopped. If the Timer_data register is set to 0. then the timer shall be stopped. 

Error handling 

5 Errors are handled by the Error handler, that can choose to skip the current command or to 
end the PCP playback. The location of the Error handler command block is stored in a 
dedicated register. The error handler returns to the next command (skip) by a return 
command, and ends the PCP playback by calling an EndO function. Different types of errors 
that can occur during the PCP playback. The error code can be read from the Error_code 
10 register. 



Error 
code 


Error type 


Description 


0 


void 


No error 


1 


Read error 


Disc damaged 


2 


Access error 


Sector address not found 


! 3 


File error 


Wrong PIN number 


! 4 


Invalid File 
number 


An invalid File_n umber was set 


5 


Command code 
error 


Command code not valid 


6 


Command index 


Command index out of range 


7 


Execution error 


Divide by 0 


8 


Invalid register 


A reserved register was addressed 


9 


Invalid Disc 
number 


A Disc_number > Disc_count was set. 


else 


reserved 
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PCP Command definitions 
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Command codes 



byte #1 opcode 



msb 



Isb 



5.3 



00 


condl 


XXX 


01 


condl 


XXX 


10 


condl 


000 


10 


cond2 


001 


10 


condl 


010 


10 


condl 


011 


10 


000 


100 


11 


condl 


000 


ti- 


cond2 


001 


ll 


condl 


100 


11 


cond2 


101 


11 


condl 


no 



byte 
#2 



Byte 
#3 



byte 
#4 



dd 
k 

k 
k 

dd 
dd 



dd 

idx 
idx 
idx 
idx 
idx 



byte 
#5 



dd 
! 

1 
I 

dd 
dd 



dd 

idx 
idx 
idx 
idx 
idx 



Opcode name 



calculate 1 xxx 
calculate xxx 

move 
move 
set const 
set random 



fill 

jump 
jump 
loop J 
Ioop2 
toop3 



C code like description 



if condl { R[j)=Rlj} opcode(xxx) dddd 
if condl | RU>RW c)pcode(xxx)Rn) ) 

if condl ( R[k}=Rni ) 
ifcond2 [ R[k}=R[IJ } 
if condl [ R[j>dddd } 
if condl | R[j)=randomvaJur, 
0o=R[j}<*dddd ); 

if (dddd=$0000) (randomize/change 
seed) 

for <n=j: n<j+i; ++n) (R|n)=dddd ) 

if condl (jumptoCmdpdx)) 
if cond2 (jump to Gndpdx)} 
if condl | -Rp); jump to Cmd[idxl J 
if coniG | -RJIJ; jump to Cmd(idxl) y 
if condl ( -R[i);-R[j];jiimpto 
Cmdfidxl) 



Notel : If an index or other value is out of range then an Exception_Error shall be executed. 
Note2: bA 7 is rnsb and ba 0 is ksb. 
5 Note3: if aD bytes #1 to #5 are equal to 0 then execution skipped as a No Operation ( NOP ). 

operand symbols 

In the PCP opcode and operand definition table special symbols are used for different 
definitions as specified in the following table. 



symbols 


length 




UM 


1 byte 


These letters are used to index variables ( e.g. variable with index i is R[i]); If i identifies 
a is reserved variable then opcode instruction is not ex ecuted 


dddd 


2 bytes 


a signed 16-bit constant where byte#4 is the msb and bvte#5 lsb 


condl 
cond2 


3 bits 


Test for execution; if the test fails then jump to next Command else execute the opcode 


idx 


2bytes 


Used for jump to a command with index = Idx 


xxx 


bits 


See separate definition table for meaning 




1 byte 


Byte is not used (VOID) 



10 



15 



opcode conditions 

Reading Array variables is done by a conditional test. If a condition is not TRUE then the 
next command entry shall be executed. The cond_l test compares a variable R[i] compared 
to 0, and the cond_2 test compares the relation between two variables R[i] and R(j] as 
defined below. 



bit 5.3 
msbJsb 


cond_l semantics 


cond_2 semantics 


%000 


True 


Rfi]=j 


%001 


Rli>0 


R|i>RUl 


%010 


R[i]<0 


R[i)<R[jl 


%011 


R(i]=0 


Rfi)=RUi 


%101 


R[i>=0 


R[i)>=R[j] 


%110 


Rfi}<^0 


Rfil<=RHl 
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opcode function definitions 

calculated function - If condl TRUE then variable R[j] indexed by byte #3 is set the 
outcome of calculation with the constant = dddd, defined by bytes #4 and #5, where byte #4 
is MSB. The type of calculation is specified by the opcode(xxx) bits 2..0, as in table below 
calculate_2 function - If cond2 TRUE then variable R[jJ indexed by byte #3 is set the 
outcome of calculation of variable R[kJ defined by byte #4 and R[1J defined by byte #5 The 
type of calculation is specified by the opcode(xxx) bits 2..0, as shown below 



xxx bits 2..0 
msb ...Isb 


Meaning 


Note 


example C-code 


ifR|k)=15 and R[IK7 then 


%000 
%001 
%010 
%011 
%100 
%101 
%110 


ADD 
SUB 
MUL 
DIV 
MOD 
AND 
OR 
XOR 


addition 
subtraction 
multiplication 
integer division 
modulo division 
logical AND 
logical OR 
logical XOR 


Ru>RlkJ + Rll) 
Ru>R[k]-Rll) 
RUHUkJ » R[IJ 
RUl=R[k]/R[l] 
Ru>Rlk)ftR[|) 
RUl=Rlk)&Rfl] 
RUl=Rrk)|R[t) 
R(il=RIkl A RJI1 


Ru>22 

RU1=8 

RU)=105 

RU)=2 

RU>1 

RU>7 

RUJ= 15 

Ru>* 



10 



15 



move function - The variable R[k] indexed by byte #4 is set equal to the variable Rfkl 
indexed by byte #5. 

set function - The variable RfiJ indexed by byte #3 is set to value dddd defined by byte #4 
and #5. 



20 



25 



random function - The variable Rfj] indexed by byte #3 is set to a random value between 0 
(zero) and dddd defined by byte #4 and #5. If dddd=0 then randomize the random generator. 

fill function - Fill N variables starting from RfiJ with dddd defined by byte #4 and #5 where 
N is equal the value of Rfi] indexed by byte #2 

jump function - Jump immediate to a command with index = idx defined by byte #4 and 

Ioop_l function - Decrement Rfi], defined by byte #2. and cond#l true then jump to the 
command with index = idx defined by byte #4 and #5. 



loop_2 function - Decrement Rfi], defined by byte #2, and if cond#2 true then jump to the 
30 command with index = idx defined by byte #4 and #5. 

loop_3 function - Decrement R[i], defined by byte #2 and decrement Rfi]. defined by byte 
#3, and cond#l true then jump to the command with index = idx defined by byte #4 and #5. 

Programming examples 

35 This section is informative. 
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1. Record carrier (1) comprising information organized in a plurality of files 
containing audio visual data (1 1) and playback control data (12) for controlling playback of 
the audiovisual data on a playback device while enabling user interaction, the information 
further comprising priority information (priority), indicating the relative priority with which 

5 the files are to be stored in a cache memory (39) of the playback device. 

2. Record carrier according to claim 1 , characterized in that the priority 
information (priority) is contained in a single file (FRT). 

10 3. Record carrier according to claim 1 , characterised in that the priority 

information (priority) is related to an estimated frequency with which the said data is 
accessed 

4. Record carrier according to claim 1, characterised in that the control data is 
15 comprised in a control program (PCP) which comprises references to menus, and that the 

data representing the control program and the menus has a relatively high priority. 

5. Playback device for playback of a record carrier (1) comprising information 
organized in a plurality of files containing audiovisual data (1 1) and playback control data 

20 (12) for controlling playback of the audiovisual data while enabling user interaction, the 
playback device comprising read means (20) for reading the data from a record carrier, a 
cache memory (39) for storing data from the record carrier, user input means (40,41) for 
receiving user input, control means (30) for processing the control data, and reproduction 
means (51-54) for reproducing the audio visual data, the device being adapted to read priority 

25 information (priority) and to store files into the cache memory with a priority determined by 
this priority information. 



WO 01/35416 PCT/EP00/11114 

6 - Playback device according to claim 5, characterized by means for rewriting the 

priority information at the record carrier in accordance with the frequency with which the 
files are actually accessed by a user. 

7. Method for playback of a record carrier (1) comprising information organized 
5 in a plurality of files containing audiovisual data and playback control data for controlling 

playback of the audiovisual data while enabling user interaction, which method comprises the 
steps of 

a. determining whether a cache memory (39) does have sufficient unoccupied 

space (S5), 

10 aa. if ^ is determined that the cache memory (39) does not have sufficient 

unoccupied space, then determining whether the cache memory does have space sufficiently 
large which is occupied by one or more further data files having a priority value lower than 
the priority value of the first data file (S6), 

aaa. if the outcome of step aa is true, then overwriting said one or more further data 

15 files by the first data file (S7), 

8. Method for playback according to claim 7, characterised in that if the outcome 
of step a is true then 

ab determining whether the first data file has a priority value higher than a 

20 predetermined value, 

aba if the outcome of step ab is true then loading the first data unit from the record 

carrier into the cache memory, 

9. Method for playback of a record carrier comprising information organized in a 
25 plurality of files containing audiovisual data and playback control data for controlling 

playback of the audiovisual data while enabling user interaction, which method comprises a 
procedure for loading files in a cache memory comprising the steps of 
d setting a reference priority value (PR),(stepS 10), 

e f or a plurality of files examining whether a priority value assigned thereto is 

30 higher than the reference priority value (step S12) 

M . if the outcome of step e is true examining whether the cache memory 

comprises sufficient space for storing the said data unit (step S13), 

eaa if the outcome of step ea is true then loading said data unit into said 

space (step SI 4), 
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f m reducing the reference priority value (S 17), 

g determining whether the reference^priority value is greater than or equal to a 

bottom priority value (SI 8), 

ga repeating steps d to g if the outcome of sfep g is true. 

5 

10, Device for recording a record carrier (1) comprising information organized in 

a plurality of files containing audio visual data (11) and playback control data (12) for 
controlling playback of the audiovisual data on a playback device while enabling user 
interaction, the information further comprising priority information (priority), indicating the 
10 relative priority with which the files are to be stored in a cache memory (39) of the playback 
device, 

the playback device comprising 
means for obtaining the audiovisual data, 
means for composing the control data, 
15 priority determining means for determining the priority information, 

formatting means for formatting the audiovisual data and the control data into files, 
recording means for recording the information comprising the priority information, the 
audiovisual data and the control data at the record carrier. 

20 11. Method for recording a record carrier ( 1 ) comprising information organized in 

a plurality of files containing audio visual data (1 1) and playback control data (12) for 
controlling playback of the audiovisual data on a playback device while enabling user 
interaction, the information further comprising priority information (priority), indicating the 
relative priority with which the files are to be stored in a cache memory (39) of the playback 
25 device, 

the method comprising the steps of 

obtaining the audiovisual data, 
composing the control data, 
determining the priority information, 
30 - formatting the audiovisual data and the control data into files, 

storing the information comprising the priority information, the audiovisual 
data and the control data at the record carrier. 



WO 01/35416 



PCI7EPO0/11114 




WO 01/35416 



PCT/EPOO/11114 




"OM05416 PCT/EP0OT1114 



3/5 



WO 01/35416 



4/5 



PCT/EPOO/11114 




